Open Source Job Scheduler
Open Source Job Scheduler
|
Developer(s) |
Software- und Organisations-Service GmbH |
Stable release |
1.3.7 / April 23, 2010; 21 months ago (2010-04-23) |
Written in |
C++, Java, JavaScript, PHP |
Operating system |
HP-UX, IBM AIX, Linux, Solaris, Vista, Win2K, Windows 7, WinXP |
Available in |
English, German |
Type |
job scheduling |
License |
GPL or closed source licence[1] |
Website |
http://www.sos-berlin.com/scheduler |
The Open Source Job Scheduler is an open source computer application for enterprise level job scheduling used for process automation. Job Scheduler is used to launch executable files and shell scripts and to run database procedures automatically.
Jobs are configurable as Web services providing interoperability with enterprise applications. It stores all information in a backend database system running on either MySQL, PostgreSQL, Firebird, SQL Server, Oracle, DB2 or Adaptive Server Enterprise.
Key Functionality
Mode of Operation
The Job Scheduler can be controlled by the built-in web server's graphical user interface. The Job Scheduler uses an XML file for the configuration of executable files or shell scripts and to set the timing and frequency of job starts.
Job Execution
- Jobs are the basic unit for the processing of executable files, shell scripts, stored procedures and of job implementations based on the Job Scheduler API.
- Jobs can be executed independently from one another. Depending on the execution result (i.e. exit status signalling success, failure or a specific exit code) of a job any number of successor jobs can be started.
- Jobs can be executed in parallel up to a configurable number of simultaneous tasks.
- Job chains can be seen as an assembly line on which multiple job nodes are passed. Therefore, each job comprises exactly one step in the processing of a job chain. Job dependencies based on execution results of the respective job nodes can be configured for a job chain.
- Monitoring of directories can trigger job starts, this allows the integration of legacy applications into the business workflow as file transfer is a widespread means to integrate applications.
- Job starts triggered by built-in calendar, by command line or by web interface.
- Other applications can start jobs or otherwise control the Job Scheduler via API’s.
Key Features
The Job Scheduler is delivered with a range of standard features, e.g.:
- Job activities can be limited to timeslots. The Job Scheduler supports any number of timeslots, which can be configured according to individual job requirements.
- The Job Scheduler allows the assignment of job priorities.
- Job history protocols are optionally stored in a database.
- The locking feature prevents two jobs accessing the same resource, e.g. a file or database, at the same time. In other words, only one process at a time can receive the exclusive right to access the resource as long as the lock is active.
- Standard job packages e.g. for log rotation and cleanup, sanity checking, job execution by remote Job Schedulers, FTP file transfer.
- Notifications for job execution results per e-mail, configurable logging and monitoring of logs.
- API to implement jobs and job scripts, e.g. for complex conditional processing.
- Different graphical user interfaces: A built-in interface for job control and a GUI for managing configurations for several Job Schedulers on different server systems.
Additional Features
- High-availability Cluster: A Job Scheduler backup cluster ensures fail-safe operation with automatic fail-over. A fail-safe system consists of a primary Job Scheduler and at least one backup, with both these Job Schedulers running on different computers.
- Load balancing: For a high volume of data with time consuming processing, using multiple Job Schedulers will speed up the processing time considerably, and provide higher availability. In load balancing mode, the processing tasks are shared between multiple Job Schedulers that are handling distributed orders on more than one host.
- Solution stacks are implementations with third party Open Source components that are available for:
Implementation
The Job Scheduler is written in C++. Standard jobs for distribution are implemented with Java (programming language).
The Open Source Job Scheduler is customized according to specific business requirements. Enterprise level support is available.
Supported Platforms
Operating Systems:
Database Management Systems:
References
External links